<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <!-- 但凡涉及到选择文件上传的操作  必然是有 input type='file' 为了美化样式 隐藏file文件域 -->
  <input type="file" hidden>
  <button>好看的按钮</button>

  <!-- 1. 隐藏file文件域
       2. 点击自己的按钮要实现文件的选择  触发file文件域的点击事件
       3. 选择文件 需要监听file文件域的change事件
       4. 获取选择的文件  console.log(e.target.files[0])
       5. 携带这个上传的文件对象 发生请求
       6. 清空当前文件域的value值
  -->
  <script>
    const file = document.querySelector('input')
    const button = document.querySelector('button')
    button.addEventListener('click',()=> { file.click() })
    file.addEventListener('change',(e)=>{
      console.log(e.target.files[0])
      // axios.post('xxxx', e.target.files[0])
      console.log('模拟发送ajax请求')

      file.value = ''
    })
  </script>
</body>
</html>